<template>
  <div class="divBox">
    <el-card class="box-card">
      <div slot="header" class="clearfix">
        <el-steps :active="currentTab" align-center finish-status="success">
          <el-step title="商品信息"/>
          <el-step title="商品详情"/>
          <el-step title="其他设置"/>
          <!--<el-step title="规格设置" />-->
        </el-steps>
      </div>
      <el-form ref="formValidate" v-loading="fullscreenLoading" class="formValidate mt20" :rules="ruleValidate"
               :model="formValidate" label-width="120px" @submit.native.prevent>
        <el-row v-show="currentTab === 0" :gutter="24">
          <!-- 商品信息-->
          <el-col v-bind="grid2">
            <el-form-item label="商品名称：" prop="storeName">
              <el-input v-model="formValidate.storeName" maxlength="128" show-word-limit placeholder="请输入商品名称"
                        :disabled="isDisabled"/>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品分类：" prop="cateIds">
              <el-cascader v-model="formValidate.cateIds" :options="merCateList" :props="props2" clearable
                           class="selWidth" :show-all-levels="false" :disabled="isDisabled"/>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品关键字：" prop="keyword">
              <el-input v-model="formValidate.keyword" placeholder="请输入商品关键字" type="textarea" :rows="5"
                        maxlength="350"
                        show-word-limit :disabled="isDisabled"/>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="单位：" prop="unitName">
              <el-input v-model="formValidate.unitName" placeholder="请输入单位" :disabled="isDisabled" maxlength="32"
                        show-word-limit/>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品简介：" prop="storeInfo">
              <el-input v-model="formValidate.storeInfo" type="textarea" maxlength="250" show-word-limit :rows="3"
                        placeholder="请输入商品简介" :disabled="isDisabled"/>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品封面图：" prop="image">
              <div class="upLoadPicBox" @click="modalPicTap('1')" :disabled="isDisabled">
                <div v-if="formValidate.image" class="pictrue"><img :src="formValidate.image"></div>
                <div v-else class="upLoad">
                  <i class="el-icon-camera cameraIconfont"/>
                </div>
              </div>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品轮播图：" prop="sliderImages">
              <div class="acea-row">
                <div v-for="(item, index) in formValidate.sliderImages" :key="index" class="pictrue" draggable="true"
                     @dragstart="handleDragStart($event, item)" @dragover.prevent="handleDragOver($event, item)"
                     @dragenter="handleDragEnter($event, item)" @dragend="handleDragEnd($event, item)">
                  <img :src="item">
                  <i v-if="!isDisabled" class="el-icon-error btndel" @click="handleRemove(index)"/>
                </div>
                <div v-if="formValidate.sliderImages.length < 10 && !isDisabled" class="upLoadPicBox"
                     @click="modalPicTap('2')">
                  <div class="upLoad">
                    <i class="el-icon-camera cameraIconfont"/>
                  </div>
                </div>
              </div>
            </el-form-item>
          </el-col>
          <el-col :xs="18" :sm="18" :md="18" :lg="12" :xl="12">
            <el-form-item label="运费模板：" prop="tempId">
              <el-select v-model="formValidate.tempId" placeholder="请选择" class="mr20" :disabled="isDisabled"
                         style="width:100%;">
                <el-option v-for="item in shippingList" :key="item.id" :label="item.name" :value="item.id"/>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :xs="6" :sm="6" :md="6" :lg="12" :xl="12">
            <el-button v-show="!isDisabled" class="mr15" @click="addTem">运费模板</el-button>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品规格：" props="specType">
              <el-radio-group v-model="formValidate.specType" @change="onChangeSpec(formValidate.specType)"
                              :disabled="isDisabled">
                <el-radio :label="false" class="radio">单规格</el-radio>
                <el-radio :label="true">多规格</el-radio>
              </el-radio-group>
            </el-form-item>
            <el-form-item label="积分商品：" props="pointProduct">
              <el-radio-group v-model="formValidate.pointProduct"
                              @change="onChangePointProduct(formValidate.pointProduct)" :disabled="isDisabled">
                <el-radio :label="1" class="radio">是</el-radio>
                <el-radio :label="0">否</el-radio>
              </el-radio-group>
            </el-form-item>
            <el-form-item label="佣金设置：" props="isSub">
              <el-radio-group v-model="formValidate.isSub" @change="onChangetype(formValidate.isSub)"
                              :disabled="isDisabled">
                <el-radio :label="true" class="radio">单独设置</el-radio>
                <el-radio :label="false">默认设置</el-radio>
              </el-radio-group>
            </el-form-item>
          </el-col>
          <!-- 多规格添加-->
          <el-col v-if="formValidate.specType && !isDisabled" :span="24" class="noForm">
            <el-form-item label="选择规格：" prop="">
              <div class="acea-row">
                <el-select v-model="formValidate.selectRule">
                  <el-option v-for="item in ruleList" :key="item.id" :label="item.ruleName" :value="item.id"/>
                </el-select>
                <el-button type="primary" class="mr20" @click="confirm">确认</el-button>
                <el-button class="mr15" @click="addRule">添加规格</el-button>
              </div>
            </el-form-item>
            <el-form-item>
              <div v-for="(item, index) in formValidate.attr" :key="index">
                <div class="acea-row row-middle"><span class="mr5">{{ item.attrName }}</span><i
                    class="el-icon-circle-close" @click="handleRemoveAttr(index)"/></div>
                <div class="rulesBox">
                  <el-tag v-for="(j, indexn) in item.attrValue" :key="indexn" closable size="medium"
                          :disable-transitions="false" class="mb5 mr10" @close="handleClose(item.attrValue, indexn)"
                          @click.native="editTag(j, indexn)">
                    <span v-if="editingAttrIndex !== indexn">{{ j }}</span>
                    <el-input
                        v-else
                        v-model="editingAttrValue"
                        size="mini"
                        ref="editInput"
                        autofocus
                        @blur="saveEdit(item.attrValue, indexn)"
                        @keyup.enter.native="saveEdit(item.attrValue, indexn)" style="min-width: 80px;"
                    />
                  </el-tag>
                  <el-input v-if="item.inputVisible" ref="saveTagInput" v-model="item.attrValue.attrsVal"
                            class="input-new-tag" size="small"
                            @keyup.enter.native="createAttr(item.attrValue.attrsVal, index)"
                            @blur="createAttr(item.attrValue.attrsVal, index)"/>
                  <el-button v-else class="button-new-tag" size="small" @click="showInput(item)">+ 添加</el-button>
                </div>
              </div>
            </el-form-item>
            <el-col v-if="isBtn">
              <el-col :xl="6" :lg="9" :md="9" :sm="24" :xs="24">
                <el-form-item label="规格：">
                  <el-input v-model="formDynamic.attrsName" placeholder="请输入规格"/>
                </el-form-item>
              </el-col>
              <el-col :xl="6" :lg="9" :md="9" :sm="24" :xs="24">
                <el-form-item label="规格值：">
                  <el-input v-model="formDynamic.attrsVal" placeholder="请输入规格值"/>
                </el-form-item>
              </el-col>
              <el-col :xl="12" :lg="6" :md="6" :sm="24" :xs="24">
                <el-form-item class="noLeft">
                  <el-button type="primary" class="mr15" @click="createAttrName">确定</el-button>
                  <el-button @click="offAttrName">取消</el-button>
                </el-form-item>
              </el-col>
            </el-col>
            <el-form-item v-if="!isBtn">
              <el-button type="primary" icon="md-add" class="mr15" @click="addBtn">添加新规格</el-button>
            </el-form-item>
          </el-col>
          <!-- 批量设置-->
          <el-col v-if="formValidate.attr.length > 0 && formValidate.specType && !isDisabled" :span="24" class="noForm">
            <el-form-item label="批量设置：">
              <el-table :data="oneFormBatch" border class="tabNumWidth" size="mini">
                <el-table-column align="center" label="图片" min-width="80">
                  <template slot-scope="scope">
                    <div class="upLoadPicBox" @click="modalPicTap('1', 'pi')">
                      <div v-if="scope.row.image" class="pictrue tabPic"><img :src="scope.row.image"></div>
                      <div v-else class="upLoad tabPic">
                        <i class="el-icon-camera cameraIconfont"/>
                      </div>
                    </div>
                  </template>
                </el-table-column>
                <el-table-column v-for="(item, iii) in attrValue" :key="iii" :label="formThead[iii].title"
                                 align="center" min-width="120">
                  <template slot-scope="scope">
                    <el-input v-model="scope.row[iii]" maxlength="9" min="0.01" class="priceBox"
                              @blur="keyupEvent(iii, scope.row[iii], scope.$index, 1)"/>
                  </template>
                </el-table-column>
                <template v-if="formValidate.isSub">
                  <el-table-column align="center" label="一级返佣(元)" min-width="120">
                    <template slot-scope="scope">
                      <el-input v-model="scope.row.brokerage" type="number" :min="0" :max="scope.row.price"
                                class="priceBox"/>
                    </template>
                  </el-table-column>
                  <el-table-column align="center" label="二级返佣(元)" min-width="120">
                    <template slot-scope="scope">
                      <el-input v-model="scope.row.brokerageTwo" type="number" :min="0" :max="scope.row.price"
                                class="priceBox"/>
                    </template>
                  </el-table-column>
                </template>
                <el-table-column align="center" label="操作" min-width="80">
                  <template>
                    <el-button type="text" class="submission" @click="batchAdd">批量添加</el-button>
                  </template>
                </el-table-column>
              </el-table>
            </el-form-item>
          </el-col>
          <el-col :xl="24" :lg="24" :md="24" :sm="24" :xs="24">
            <!-- 单规格表格-->
            <el-form-item v-if="formValidate.specType === false">
              <el-table :data="OneattrValue" border class="tabNumWidth" size="mini">

                <el-table-column align="center" label="代理价" min-width="80" width="200">
                  <template slot-scope="scope">
                    <el-table :show-header="false" :data="scope.row.alPriceList" size="mini" align="center">
                      <el-table-column align="center" label="代理价格名" prop="agentPriceName">
                      </el-table-column>
                      <el-table-column align="center" label="代理价格" prop="agentPrice">
                        <template slot-scope="scope2">
                          <el-input v-model="scope2.row.agentPrice" type="number" size="mini" :min="0"/>
                        </template>
                      </el-table-column>
                    </el-table>
                  </template>
                </el-table-column>

                <el-table-column align="center" label="图片" min-width="80">
                  <template slot-scope="scope">
                    <div class="upLoadPicBox" @click="modalPicTap('1', 'dan', 'pi')">
                      <div v-if="formValidate.image" class="pictrue tabPic"><img :src="scope.row.image"></div>
                      <div v-else class="upLoad tabPic">
                        <i class="el-icon-camera cameraIconfont"/>
                      </div>
                    </div>
                  </template>
                </el-table-column>
                <el-table-column v-for="(item, iii) in attrValue" :key="iii" :label="formThead[iii].title"
                                 align="center" min-width="120">
                  <template slot-scope="scope">
                    <el-input :disabled="isDisabled" v-model="scope.row[iii]" maxlength="9" min="0.01" class="priceBox"
                              @blur="keyupEvent(iii, scope.row[iii], scope.$index, 2)"/>
                  </template>
                </el-table-column>
                <template v-if="formValidate.isSub">
                  <el-table-column align="center" label="一级返佣(元)" min-width="120">
                    <template slot-scope="scope">
                      <el-input :disabled="isDisabled" v-model="scope.row.brokerage" type="number" :min="0"
                                class="priceBox"/>
                    </template>
                  </el-table-column>
                  <el-table-column align="center" label="二级返佣(元)" min-width="120">
                    <template slot-scope="scope">
                      <el-input :disabled="isDisabled" v-model="scope.row.brokerageTwo" type="number" :min="0"
                                class="priceBox"/>
                    </template>
                  </el-table-column>
                </template>
              </el-table>
            </el-form-item>
            <!-- <div>manyTabDate:{{manyTabDate}}</div> -->
            <el-form-item label="全部sku:" v-if="$route.params.id && showAll">
              <el-button type="default" @click="showAllSku()" :disabled="isDisabled">展示</el-button>
            </el-form-item>
            <!-- 多规格表格-->
            <el-form-item v-if="formValidate.attr.length > 0 && formValidate.specType" label="商品属性："
                          class="labeltop"
                          :class="isDisabled ? 'disLabel' : 'disLabelmoren'">
              <el-table :data="ManyAttrValue" border class="tabNumWidth" size="mini">

                <el-table-column align="center" label="代理价" min-width="80" width="200">
                  <template slot-scope="scope">
                    <el-table :show-header="false" :data="scope.row.alPriceList" size="mini" align="center">
                      <el-table-column align="center" label="代理价格名" prop="agentPriceName">
                      </el-table-column>
                      <el-table-column align="center" label="代理价格" prop="agentPrice">
                        <template slot-scope="scope2">
                          <el-input v-model="scope2.row.agentPrice" type="number" size="mini" :min="0"/>
                        </template>
                      </el-table-column>
                    </el-table>
                  </template>
                </el-table-column>

                <template v-if="manyTabDate">
                  <el-table-column v-for="(item, iii) in manyTabDate" :key="iii" align="center"
                                   :label="manyTabTit[iii].title" min-width="80">
                    <template slot-scope="scope">
                      <span class="priceBox" v-text="scope.row[iii]"/>
                    </template>
                  </el-table-column>
                </template>

                <el-table-column align="center" label="图片" min-width="80">
                  <template slot-scope="scope">
                    <div class="upLoadPicBox" @click="modalPicTap('1', 'duo', scope.$index)">
                      <div v-if="scope.row.image" class="pictrue tabPic"><img :src="scope.row.image"></div>
                      <div v-else class="upLoad tabPic">
                        <i class="el-icon-camera cameraIconfont"/>
                      </div>
                    </div>
                  </template>
                </el-table-column>
                <el-table-column v-for="(item, iii) in attrValue" :key="iii" :label="formThead[iii].title"
                                 align="center" min-width="120">
                  <template slot-scope="scope">
                    <!-- <span>scope.row:{{scope.row}}</span> -->
                    <el-input :disabled="isDisabled" maxlength="9" min="0.01" v-model="scope.row[iii]" class="priceBox"
                              @blur="keyupEvent(iii, scope.row[iii], scope.$index, 3)"/>
                  </template>
                </el-table-column>
                <el-table-column align="center" label="一级返佣(元)" min-width="120" v-if="formValidate.isSub">
                  <template slot-scope="scope">
                    <el-input :disabled="isDisabled" v-model="scope.row.brokerage" type="number" :min="0"
                              :max="scope.row.price" class="priceBox"/>
                  </template>
                </el-table-column>
                <el-table-column align="center" label="二级返佣(元)" min-width="120" v-if="formValidate.isSub">
                  <template slot-scope="scope">
                    <el-input :disabled="isDisabled" v-model="scope.row.brokerageTwo" type="number" :min="0"
                              :max="scope.row.price" class="priceBox"/>
                  </template>
                </el-table-column>
                <el-table-column align="center" label="代理展示" min-width="150">
                  <template slot-scope="scope">
                    <el-select :disabled="isDisabled" v-model="scope.row.agents"
                               title="请选择代理展示，不选全部显示,只对代理生效"
                               placeholder="请选择代理展示，不选全部显示" multiple clearable filterable>
                      <el-option v-for="item in agentList" :key="item.aid" :label="item.agentName" :value="item.aid">
                      </el-option>
                    </el-select>
                  </template>
                </el-table-column>
                <el-table-column v-if="!isDisabled" key="3" align="center" label="操作" min-width="80">
                  <template slot-scope="scope">
                    <el-button type="text" class="submission" @click="delAttrTable(scope.$index)">删除</el-button>
                  </template>
                </el-table-column>
              </el-table>
            </el-form-item>
          </el-col>
        </el-row>
        <!-- 商品详情-->
        <el-row v-show="currentTab === 1 && !isDisabled">
          <el-col :span="24">
            <el-form-item label="商品详情：">
              <Tinymce v-model="formValidate.content"></Tinymce>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row v-show="currentTab === 1 && isDisabled">
          <el-col :span="24">
            <el-form-item label="商品详情：">
              <span v-html="formValidate.content || '无'"></span>
            </el-form-item>
          </el-col>
        </el-row>
        <!-- 其他设置-->
        <el-row v-show="currentTab === 2">
          <el-col :span="24">
            <el-col v-bind="grid">
              <el-form-item label="排序：">
                <el-input-number v-model="formValidate.sort" :min="0" placeholder="请输入排序" :disabled="isDisabled"/>
              </el-form-item>
            </el-col>
            <el-col v-bind="grid">
              <el-form-item label="积分：">
                <el-input-number v-model="formValidate.giveIntegral" :min="0" placeholder="请输入排序"
                                 :disabled="isDisabled"/>
              </el-form-item>
            </el-col>
            <el-col v-bind="grid">
              <el-form-item label="虚拟销量：">
                <el-input-number v-model="formValidate.ficti" :min="0" placeholder="请输入排序" :disabled="isDisabled"/>
              </el-form-item>
            </el-col>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品推荐：">
              <el-checkbox-group v-model="checkboxGroup" size="small" @change="onChangeGroup" :disabled="isDisabled">
                <el-checkbox v-for="(item, index) in recommend" :key="index" :label="item.value">{{
                    item.name
                  }}
                </el-checkbox>
              </el-checkbox-group>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="活动优先级：">
              <div class="color-list acea-row row-middle">
                <div :disabled="isDisabled" class="color-item" :class="activity[item]"
                     v-for="item in formValidate.activity" :key="item" draggable="true"
                     @dragstart="handleDragStart($event, item)" @dragover.prevent="handleDragOver($event, item)"
                     @dragenter="handleDragEnterFont($event, item)" @dragend="handleDragEnd($event, item)">{{ item }}
                </div>
                <div class="tip">可拖动按钮调整活动的优先展示顺序</div>
              </div>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="优惠券：" class="proCoupon">
              <div class="acea-row">
                <el-tag v-for="(tag, index) in formValidate.coupons" :key="index" class="mr10 mb10"
                        :closable="!isDisabled" :disable-transitions="false" @close="handleCloseCoupon(tag)">
                  {{ tag.name }}
                </el-tag>
                <!-- <span v-if="formValidate.couponIds == null">无</span> -->
                <el-button v-if="!isDisabled" class="mr15" @click="addCoupon">选择优惠券</el-button>
              </div>
            </el-form-item>
          </el-col>
        </el-row>
        <el-form-item>
          <el-button v-show="currentTab > 0" class="submission priamry_border" @click="handleSubmitUp">上一步
          </el-button>
          <el-button v-show="currentTab < 2" type="primary" class="submission"
                     @click="handleSubmitNest('formValidate')">下一步
          </el-button>
          <el-button v-show="(currentTab === 2 || $route.params.id) && !isDisabled" type="primary" class="submission"
                     @click="handleSubmit('formValidate')">提交
          </el-button>
        </el-form-item>
      </el-form>
    </el-card>
    <CreatTemplates ref="addTemplates" @getList="getShippingList"/>
  </div>
</template>

<script>
import Tinymce from '@/components/Tinymce/index'
import {templateListApi, productCreateApi, categoryApi, productDetailApi, productUpdateApi} from '@/api/store'
import {marketingSendApi} from '@/api/marketing';
import {shippingTemplatesList} from '@/api/logistics'
import {goodDesignList} from "@/api/systemGroup";
import {clearTreeData} from '@/utils/ZBKJIutil'
import CreatTemplates from '@/views/systemSetting/logistics/shippingTemplates/creatTemplates'
import Templates from "../../appSetting/wxAccount/wxTemplate/index";
import {Debounce} from '@/utils/validate'
import {agentLevelAll} from "@/api/agentlevel"
import {agentListAll} from "@/api/agent"

let defaultObj = {
  image: '',
  sliderImages: [],
  videoLink: '',
  sliderImage: '',
  storeName: '',
  storeInfo: '',
  keyword: '',
  cateIds: [], // 商品分类id
  cateId: null, // 商品分类id传值
  unitName: '',
  sort: 0,
  giveIntegral: 0,
  ficti: 0,
  isShow: false,
  isBenefit: false,
  isNew: false,
  isGood: false,
  isHot: false,
  isBest: false,
  pointProduct: 0,
  tempId: '',
  attrValue: [{
    image: '',
    price: 0,
    cost: 0,
    otPrice: 0,
    stock: 0,
    barCode: '',
    weight: 0,
    volume: 0,
  }],
  attr: [],
  selectRule: '',
  isSub: false,
  content: '',
  specType: undefined,
  id: 0,
  couponIds: [],
  coupons: [],
  activity: ['默认', '秒杀', '砍价', '拼团']
}
const objTitle = {
  price: {
    title: '售价'
  },
  cost: {
    title: '成本价'
  },
  otPrice: {
    title: '原价'
  },
  stock: {
    title: '库存'
  },
  barCode: {
    title: '商品编号'
  },
  weight: {
    title: '重量（KG）'
  },
  volume: {
    title: '体积(m³)'
  }
}
export default {
  name: 'ProductProductAdd',
  components: {Templates, CreatTemplates, Tinymce},
  data() {
    return {
      editingAttrIndex: -1, // 当前正在编辑的索引
      editingAttrValue: '', // 正在编辑的值
      isDisabled: this.$route.params.isDisabled === '1' ? true : false,
      activity: {'默认': 'red', '秒杀': 'blue', '砍价': 'green', '拼团': 'yellow'},
      props2: {
        children: 'child',
        label: 'name',
        value: 'id',
        multiple: true,
        emitPath: false
      },
      checkboxGroup: [],
      recommend: [],
      tabs: [],
      fullscreenLoading: false,
      props: {multiple: true},
      active: 0,
      OneattrValue: [Object.assign({}, defaultObj.attrValue[0])], // 单规格
      ManyAttrValue: [Object.assign({}, defaultObj.attrValue[0])], // 多规格
      ruleList: [],
      merCateList: [], // 商户分类筛选
      shippingList: [], // 运费模板
      formThead: Object.assign({}, objTitle),
      formValidate: Object.assign({}, defaultObj),
      formDynamics: {
        ruleName: '',
        ruleValue: []
      },
      tempData: {
        page: 1,
        limit: 9999
      },
      manyTabTit: {},
      manyTabDate: {},
      grid2: {
        xl: 12,
        lg: 12,
        md: 12,
        sm: 24,
        xs: 24
      },
      // 规格数据
      formDynamic: {
        attrsName: '',
        attrsVal: ''
      },
      isBtn: false,
      manyFormValidate: [],
      currentTab: 0,
      isChoice: '',
      grid: {
        xl: 8,
        lg: 8,
        md: 12,
        sm: 24,
        xs: 24
      },
      ruleValidate: {
        storeName: [
          {required: true, message: '请输入商品名称', trigger: 'blur'}
        ],
        cateIds: [
          {required: true, message: '请选择商品分类', trigger: 'change', type: 'array', min: '1'}
        ],
        keyword: [
          {required: true, message: '请输入商品关键字', trigger: 'blur'}
        ],
        unitName: [
          {required: true, message: '请输入单位', trigger: 'blur'}
        ],
        storeInfo: [
          {required: true, message: '请输入商品简介', trigger: 'blur'}
        ],
        tempId: [
          {required: true, message: '请选择运费模板', trigger: 'change'}
        ],
        image: [
          {required: true, message: '请上传商品图', trigger: 'change'}
        ],
        sliderImages: [
          {required: true, message: '请上传商品轮播图', type: 'array', trigger: 'change'}
        ],
        specType: [
          {required: true, message: '请选择商品规格', trigger: 'change'}
        ]
      },
      attrInfo: {},
      tableFrom: {
        page: 1,
        limit: 9999,
        keywords: ''
      },
      tempRoute: {},
      keyNum: 0,
      isAttr: false,
      showAll: false,
      videoLink: "",
      defaultAgentPriceList: [],
      agentList: []
    }
  },
  computed: {
    attrValue() {
      const obj = Object.assign({}, defaultObj.attrValue[0])
      delete obj.image
      return obj
    },
    oneFormBatch() {
      const obj = [Object.assign({}, defaultObj.attrValue[0])]
      delete obj[0].barCode
      return obj
    }
  },
  watch: {
    'formValidate.attr': {
      handler: function (val) {
        if (this.formValidate.specType && this.isAttr) this.watCh(val) //重要！！！
      },
      immediate: false,
      deep: true
    }
  },
  created() {
    this.getAgentLevel()
    this.getAgentAll()

    this.tempRoute = Object.assign({}, this.$route)
    if (this.$route.params.id && this.formValidate.specType) {
      this.$watch('formValidate.attr', this.watCh)
    }
    console.log("created", this.OneattrValue)
  },
  mounted() {
    this.formValidate.sliderImages = []
    if (this.$route.params.id) {
      this.setTagsViewTitle()
      this.getInfo()
    }
    this.getCategorySelect()
    this.getShippingList()
    this.getGoodsType()

  },
  methods: {
    editTag(value, index) {
      if (this.isDisabled) return;
      this.editingAttrIndex = index;
      this.editingAttrValue = value;

      // 使用 $nextTick 等待 DOM 更新后再手动聚焦
      this.$nextTick(() => {
        const inputRef = this.$refs.editInput;
        console.log("输入框",inputRef);
        if (inputRef && inputRef[0]) {
          inputRef[0].focus();
        }
      });
    },
    saveEdit(attrArray, index) {
      console.log("保存编辑",index)
      attrArray[index] = this.editingAttrValue; // 替换原数组中的值
      this.editingAttrIndex = -1; // 清除编辑状态
      this.editingAttrValue = '';
    },
    getAgentAll() {
      agentListAll().then(res => {
        console.log("代理商：", res)
        this.agentList = res
      })
    },
    getAgentLevel() {
      agentLevelAll().then(res => {

        let arr = []
        for (let index = 0; index < res.length; index++) {
          const element = res[index];
          let obj = {
            agentPriceName: element.agentName + '价',
            agentPrice: 0,
            alId: element.alId
          }
          arr.push(obj)
        }
        this.defaultAgentPriceList = arr;

        // 设置空代理价格项
        for (let index = 0; index < this.OneattrValue.length; index++) {
          const element = this.OneattrValue[index];

          if (!element.alPriceList) {
            element.alPriceList = JSON.parse(JSON.stringify(this.defaultAgentPriceList))
          }
        }

      })
    },
    // 校验输入框不能输入0，保留2位小数，库存为正整数
    keyupEvent(key, val, index, num) {
      if (key === 'barCode') return;
      var re = /^\D*([0-9]\d*\.?\d{0,2})?.*$/;
      switch (num) {
        case 1:
          if (val == 0) {
            this.oneFormBatch[index][key] = key === 'stock' ? 0 : 0.01;
          } else {
            this.oneFormBatch[index][key] =
                key === 'stock'
                    ? parseInt(val)
                    : this.$set(this.oneFormBatch[index], key, val.toString().replace(re, '$1'));
          }
          break;
        case 2:
          if (val == 0) {
            this.OneattrValue[index][key] = key === 'stock' ? 0 : 0.01;
          } else {
            this.OneattrValue[index][key] =
                key === 'stock'
                    ? parseInt(val)
                    : this.$set(this.OneattrValue[index], key, val.toString().replace(re, '$1'));
          }
          break;
        default:
          if (val == 0) {
            this.ManyAttrValue[index][key] = key === 'stock' ? 0 : 0.01;
          } else {
            this.ManyAttrValue[index][key] =
                key === 'stock'
                    ? parseInt(val)
                    : this.$set(this.ManyAttrValue[index], key, val.toString().replace(re, '$1'));
          }
          break;
      }
    },
    handleCloseCoupon(tag) {
      this.isAttr = true
      this.formValidate.coupons.splice(this.formValidate.coupons.indexOf(tag), 1)
      this.formValidate.couponIds.splice(this.formValidate.couponIds.indexOf(tag.id), 1)
    },
    addCoupon() {
      const _this = this
      this.$modalCoupon('wu', this.keyNum += 1, this.formValidate.coupons, function (row) {
        _this.formValidate.couponIds = []
        _this.formValidate.coupons = row
        row.map((item) => {
          _this.formValidate.couponIds.push(item.id)
        })
      }, '')
    },
    setTagsViewTitle() {
      const title = this.isDisabled ? '商品详情' : '编辑商品'
      const route = Object.assign({}, this.tempRoute, {title: `${title}-${this.$route.params.id}`})
      this.$store.dispatch('tagsView/updateVisitedView', route)
    },
    onChangeGroup() {
      this.checkboxGroup.includes('isGood') ? this.formValidate.isGood = true : this.formValidate.isGood = false
      this.checkboxGroup.includes('isBenefit') ? this.formValidate.isBenefit = true : this.formValidate.isBenefit = false
      this.checkboxGroup.includes('isBest') ? this.formValidate.isBest = true : this.formValidate.isBest = false
      this.checkboxGroup.includes('isNew') ? this.formValidate.isNew = true : this.formValidate.isNew = false
      this.checkboxGroup.includes('isHot') ? this.formValidate.isHot = true : this.formValidate.isHot = false
    },
    watCh(val) {
      console.log("watCh");
      const tmp = {}
      const tmpTab = {}
      this.formValidate.attr.forEach((o, i) => {
        // tmp['value' + i] = { title: o.attrName }
        // tmpTab['value' + i] = ''
        tmp[o.attrName] = {title: o.attrName};
        tmpTab[o.attrName] = '';
      });
      this.ManyAttrValue = this.attrFormat(val);
      this.ManyAttrValue.forEach((val, index) => {
        const key = Object.values(val.attrValue).sort().join('/')
        if (this.attrInfo[key]) this.ManyAttrValue[index] = this.attrInfo[key]
      })
      this.attrInfo = [];
      this.ManyAttrValue.forEach((val) => {
        this.attrInfo[Object.values(val.attrValue).sort().join('/')] = val
      })

      for (let index = 0; index < this.ManyAttrValue.length; index++) {
        const element = this.ManyAttrValue[index];
        if (!element.alPriceList) {
          element.alPriceList = JSON.parse(JSON.stringify(this.defaultAgentPriceList))
        }
      }
      this.manyTabTit = tmp
      this.manyTabDate = tmpTab
      this.formThead = Object.assign({}, this.formThead, tmp)

    },
    attrFormat(arr) {
      let data = []
      const res = []
      return format(arr)

      function format(arr) {
        if (arr.length > 1) {
          arr.forEach((v, i) => {
            if (i === 0) data = arr[i]['attrValue']
            const tmp = []
            if (!data) return;
            data.forEach(function (vv) {
              arr[i + 1] && arr[i + 1]['attrValue'] && arr[i + 1]['attrValue'].forEach(g => {
                const rep2 = (i !== 0 ? '' : arr[i]['attrName'] + '_') + vv + '$&' + arr[i + 1]['attrName'] + '_' + g
                tmp.push(rep2)
                if (i === (arr.length - 2)) {
                  const rep4 = {
                    image: '',
                    price: 0,
                    cost: 0,
                    otPrice: 0,
                    stock: 0,
                    barCode: '',
                    weight: 0,
                    volume: 0,
                    brokerage: 0,
                    brokerage_two: 0
                  }
                  rep2.split('$&').forEach((h, k) => {
                    const rep3 = h.split('_');
                    if (!rep4['attrValue']) rep4['attrValue'] = {}
                    rep4['attrValue'][rep3[0]] = rep3.length > 1 ? rep3[1] : ''
                  })
                  for (let attrValueKey in rep4.attrValue) {
                    rep4[attrValueKey] = rep4.attrValue[attrValueKey];
                  }
                  res.push(rep4)
                }
              })
            })
            data = tmp.length ? tmp : []
          })
        } else {
          const dataArr = []
          arr.forEach((v, k) => {
            v['attrValue'].forEach((vv, kk) => {
              dataArr[kk] = v['attrName'] + '_' + vv
              res[kk] = {
                image: '',
                price: 0,
                cost: 0,
                otPrice: 0,
                stock: 0,
                barCode: '',
                weight: 0,
                volume: 0,
                brokerage: 0,
                brokerage_two: 0,
                attrValue: {[v['attrName']]: vv}
              }
              // Object.values(res[kk].attrValue).forEach((v, i) => {
              //   res[kk]['value' + i] = v
              // })
              for (let attrValueKey in res[kk].attrValue) {
                res[kk][attrValueKey] = res[kk].attrValue[attrValueKey];
              }
            })
          })
          data.push(dataArr.join('$&'))
        }
        return res
      }
    },
    // 运费模板
    addTem() {
      this.$refs.addTemplates.dialogVisible = true
      this.$refs.addTemplates.getCityList()
    },
    // 添加规则；
    addRule() {
      const _this = this
      this.$modalAttr(this.formDynamics, function () {
        _this.productGetRule()
      })
    },
    onChangePointProduct(val) {
      if (val == 1) {
        this.ruleValidate = {
          storeName: [
            {required: true, message: '请输入商品名称', trigger: 'blur'}
          ],
          keyword: [
            {required: true, message: '请输入商品关键字', trigger: 'blur'}
          ],
          unitName: [
            {required: true, message: '请输入单位', trigger: 'blur'}
          ],
          storeInfo: [
            {required: true, message: '请输入商品简介', trigger: 'blur'}
          ],
          tempId: [
            {required: true, message: '请选择运费模板', trigger: 'change'}
          ],
          image: [
            {required: true, message: '请上传商品图', trigger: 'change'}
          ],
          sliderImages: [
            {required: true, message: '请上传商品轮播图', type: 'array', trigger: 'change'}
          ],
          specType: [
            {required: true, message: '请选择商品规格', trigger: 'change'}
          ]
        }
      } else {
        this.ruleValidate = {
          storeName: [
            {required: true, message: '请输入商品名称', trigger: 'blur'}
          ],
          cateIds: [
            {required: true, message: '请选择商品分类', trigger: 'change', type: 'array', min: '1'}
          ],
          keyword: [
            {required: true, message: '请输入商品关键字', trigger: 'blur'}
          ],
          unitName: [
            {required: true, message: '请输入单位', trigger: 'blur'}
          ],
          storeInfo: [
            {required: true, message: '请输入商品简介', trigger: 'blur'}
          ],
          tempId: [
            {required: true, message: '请选择运费模板', trigger: 'change'}
          ],
          image: [
            {required: true, message: '请上传商品图', trigger: 'change'}
          ],
          sliderImages: [
            {required: true, message: '请上传商品轮播图', type: 'array', trigger: 'change'}
          ],
          specType: [
            {required: true, message: '请选择商品规格', trigger: 'change'}
          ]
        }
      }
    },
    // 选择规格
    onChangeSpec(num) {
      this.isAttr = true;
      if (num) this.productGetRule()
    },
    // 选择属性确认
    confirm() {
      this.isAttr = true
      if (!this.formValidate.selectRule) {
        return this.$message.warning('请选择属性')
      }
      const data = []
      this.ruleList.forEach(item => {
        if (item.id === this.formValidate.selectRule) {
          item.ruleValue.forEach(i => {
            data.push({
              attrName: i.value,
              attrValue: i.detail
            })
          })
        }
        this.formValidate.attr = data;
      });


    },
    // 商品分类；
    getCategorySelect() {
      categoryApi({status: -1, type: 1}).then(res => {
        this.merCateList = this.filerMerCateList(res)
        let newArr = [];
        res.forEach((value, index) => {
          newArr[index] = value;
          if (value.child) newArr[index].child = value.child.filter(item => item.status === true)
        }) //过滤商品分类设置为隐藏的子分类不出现在树形列表里
        this.merCateList = this.filerMerCateList(newArr)
      })
    },
    filerMerCateList(treeData) {
      return treeData.map((item) => {
        if (!item.child) {
          item.disabled = true
        }
        item.label = item.name
        return item
      })
    },
    // 获取商品属性模板；
    productGetRule() {
      templateListApi(this.tableFrom).then(res => {
        const list = res.list
        for (var i = 0; i < list.length; i++) {
          list[i].ruleValue = JSON.parse(list[i].ruleValue)
        }
        this.ruleList = list
      })
    },
    // 运费模板；
    getShippingList() {
      shippingTemplatesList(this.tempData).then(res => {
        this.shippingList = res.list
      })
    },
    showInput(item) {
      this.$set(item, 'inputVisible', true)
    },
    onChangetype(item) {
      if (item === 1) {
        this.OneattrValue.map(item => {
          this.$set(item, 'brokerage', null)
          this.$set(item, 'brokerageTwo', null)
        })
        this.ManyAttrValue.map(item => {
          this.$set(item, 'brokerage', null)
          this.$set(item, 'brokerageTwo', null)
        })
      } else {
        this.OneattrValue.map(item => {
          delete item.brokerage
          delete item.brokerageTwo
          this.$set(item, 'brokerage', null)
          this.$set(item, 'brokerageTwo', null)
        })
        this.ManyAttrValue.map(item => {
          delete item.brokerage
          delete item.brokerageTwo
        })
      }
    },
    // 删除表格中的属性
    delAttrTable(index) {
      this.ManyAttrValue.splice(index, 1)
    },
    // 批量添加
    batchAdd() {
      // if (!this.oneFormBatch[0].pic || !this.oneFormBatch[0].price || !this.oneFormBatch[0].cost || !this.oneFormBatch[0].ot_price ||
      //     !this.oneFormBatch[0].stock || !this.oneFormBatch[0].bar_code) return this.$Message.warning('请填写完整的批量设置内容！');
      for (const val of this.ManyAttrValue) {
        this.$set(val, 'image', this.oneFormBatch[0].image)
        this.$set(val, 'price', this.oneFormBatch[0].price)
        this.$set(val, 'cost', this.oneFormBatch[0].cost)
        this.$set(val, 'otPrice', this.oneFormBatch[0].otPrice)
        this.$set(val, 'stock', this.oneFormBatch[0].stock)
        this.$set(val, 'barCode', this.oneFormBatch[0].barCode)
        this.$set(val, 'weight', this.oneFormBatch[0].weight)
        this.$set(val, 'volume', this.oneFormBatch[0].volume)
        this.$set(val, 'brokerage', this.oneFormBatch[0].brokerage)
        this.$set(val, 'brokerageTwo', this.oneFormBatch[0].brokerageTwo)
      }
    },
    // 添加按钮
    addBtn() {
      this.clearAttr()
      this.isBtn = true
    },
    // 取消
    offAttrName() {
      this.isBtn = false
    },
    clearAttr() {
      this.isAttr = true
      this.formDynamic.attrsName = ''
      this.formDynamic.attrsVal = ''
    },
    // 删除规格
    handleRemoveAttr(index) {
      this.isAttr = true
      this.formValidate.attr.splice(index, 1)
      this.manyFormValidate.splice(index, 1)
    },
    // 删除属性
    handleClose(item, index) {
      item.splice(index, 1)
    },
    // 添加规则名称
    createAttrName() {
      this.isAttr = true
      if (this.formDynamic.attrsName && this.formDynamic.attrsVal) {
        const data = {
          attrName: this.formDynamic.attrsName,
          attrValue: [
            this.formDynamic.attrsVal
          ]
        }
        this.formValidate.attr.push(data)
        var hash = {}
        this.formValidate.attr = this.formValidate.attr.reduce(function (item, next) {
          /* eslint-disable */
          hash[next.attrName] ? '' : hash[next.attrName] = true && item.push(next)
          return item
        }, [])
        this.clearAttr()
        this.isBtn = false
      } else {
        this.$Message.warning('请添加完整的规格！');
      }
    },
    // 添加属性
    createAttr(num, idx) {
      this.isAttr = true
      if (num) {
        this.formValidate.attr[idx].attrValue.push(num);
        var hash = {};
        this.formValidate.attr[idx].attrValue = this.formValidate.attr[idx].attrValue.reduce(function (item, next) {
          /* eslint-disable */
          hash[next] ? '' : hash[next] = true && item.push(next);
          this.$message.warning(next + '已添加');
          return item
        }, []);
        this.formValidate.attr[idx].inputVisible = false
      } else {
        this.$message.warning('请添加属性');
      }
    },
    //点击展示所有多规格属性
    showAllSku() {
      if (this.isAttr == false) {
        this.isAttr = true;
        if (this.formValidate.specType && this.isAttr) this.watCh(this.formValidate.attr) //重要！！！
      } else if (this.isAttr == true) {
        this.isAttr = false;
        this.getInfo();
      }
    },
    // 详情
    getInfo() {
      this.fullscreenLoading = true
      productDetailApi(this.$route.params.id).then(async res => {
        // this.isAttr = true;
        let info = res
        this.formValidate = {
          image: this.$selfUtil.setDomain(info.image),
          sliderImage: info.sliderImage,
          sliderImages: JSON.parse(info.sliderImage),
          storeName: info.storeName,
          storeInfo: info.storeInfo,
          keyword: info.keyword,
          cateIds: info.cateId.split(','), // 商品分类id
          cateId: info.cateId,// 商品分类id传值
          unitName: info.unitName,
          sort: info.sort,
          isShow: info.isShow,
          isBenefit: info.isBenefit,
          isNew: info.isNew,
          isGood: info.isGood,
          isHot: info.isHot,
          isBest: info.isBest,
          pointProduct: info.pointProduct,
          tempId: info.tempId,
          attr: info.attr,
          attrValue: info.attrValue,
          selectRule: info.selectRule,
          isSub: info.isSub,
          content: this.$selfUtil.replaceImgSrcHttps(info.content),
          specType: info.specType,
          id: info.id,
          giveIntegral: info.giveIntegral,
          ficti: info.ficti,
          coupons: info.coupons,
          couponIds: info.couponIds,
          activity: info.activityStr ? info.activityStr.split(',') : ['默认', '秒杀', '砍价', '拼团']
        }

        if (info.pointProduct == 1) {
          this.ruleValidate = {
            storeName: [
              {required: true, message: '请输入商品名称', trigger: 'blur'}
            ],
            keyword: [
              {required: true, message: '请输入商品关键字', trigger: 'blur'}
            ],
            unitName: [
              {required: true, message: '请输入单位', trigger: 'blur'}
            ],
            storeInfo: [
              {required: true, message: '请输入商品简介', trigger: 'blur'}
            ],
            tempId: [
              {required: true, message: '请选择运费模板', trigger: 'change'}
            ],
            image: [
              {required: true, message: '请上传商品图', trigger: 'change'}
            ],
            sliderImages: [
              {required: true, message: '请上传商品轮播图', type: 'array', trigger: 'change'}
            ],
            specType: [
              {required: true, message: '请选择商品规格', trigger: 'change'}
            ]
          }
        }

        marketingSendApi({type: 3}).then(res => {
          if (this.formValidate.couponIds !== null) {
            let ids = this.formValidate.couponIds.toString();
            let arr = res.list;
            let obj = {};
            for (let i in arr) {
              obj[arr[i].id] = arr[i];
            }
            let strArr = ids.split(',');
            let newArr = [];
            for (let item of strArr) {
              if (obj[item]) {
                newArr.push(obj[item]);
              }
            }
            this.$set(this.formValidate, 'coupons', newArr); //在编辑回显时，让返回数据中的优惠券id，通过接口匹配显示,
          }
        })
        let imgs = JSON.parse(info.sliderImage)
        let imgss = []
        Object.keys(imgs).map(i => {
          imgss.push(this.$selfUtil.setDomain(imgs[i]))
        })
        this.formValidate.sliderImages = [...imgss]
        if (info.isHot) this.checkboxGroup.push('isHot')
        if (info.isGood) this.checkboxGroup.push('isGood')
        if (info.isBenefit) this.checkboxGroup.push('isBenefit')
        if (info.isBest) this.checkboxGroup.push('isBest')
        if (info.isNew) this.checkboxGroup.push('isNew')
        this.productGetRule()
        if (info.specType) {
          this.formValidate.attr = info.attr.map(item => {
            return {
              attrName: item.attrName,
              attrValue: item.attrValues.split(',')
            }
          })
          this.ManyAttrValue = info.attrValue;
          this.ManyAttrValue.forEach((val) => {
            val.image = this.$selfUtil.setDomain(val.image);
            val.attrValue = JSON.parse(val.attrValue);
            this.attrInfo[Object.values(val.attrValue).sort().join('/')] = val;
          })
          /***多规格商品如果被删除过sku，优先展示api返回的数据,否则会有没有删除的错觉***/
          let manyAttr = this.attrFormat(this.formValidate.attr)
          if (manyAttr.length !== this.ManyAttrValue.length) {
            this.$set(this, 'showAll', true)
            this.isAttr = false;
          } else {
            this.isAttr = true;
          }
          /*******/
          const tmp = {}
          const tmpTab = {}
          this.formValidate.attr.forEach((o, i) => {
            // tmp['value' + i] = { title: o.attrName }
            // tmpTab['value' + i] = ''
            tmp[o.attrName] = {title: o.attrName};
            tmpTab[o.attrName] = '';
          })

          console.log("tmp", tmp);

          // 此处手动实现后台原本value0 value1的逻辑
          this.formValidate.attrValue.forEach(item => {
            for (let attrValueKey in item.attrValue) {
              item[attrValueKey] = item.attrValue[attrValueKey];
            }
          });
          console.log("tmpTab", tmpTab);

          this.manyTabTit = tmp
          this.manyTabDate = tmpTab
          this.formThead = Object.assign({}, this.formThead, tmp)
        } else {
          this.OneattrValue = info.attrValue
          // this.formValidate.attr = [] //单规格商品规格设置为空
        }
        this.fullscreenLoading = false
      }).catch(res => {
        this.fullscreenLoading = false
        this.$message.error(res.message);
      });
    },
    handleRemove(i) {
      this.formValidate.sliderImages.splice(i, 1)
    },
    // 点击商品图
    modalPicTap(tit, num, i, status) {
      const _this = this;
      if (_this.isDisabled) return;
      this.$modalUpload(function (img) {
        if (tit === '1' && !num) {
          _this.formValidate.image = img[0].sattDir
          _this.OneattrValue[0].image = img[0].sattDir
        }
        if (tit === '2' && !num) {
          if (img.length > 10) return this.$message.warning("最多选择10张图片！");
          if (img.length + _this.formValidate.sliderImages.length > 10) return this.$message.warning("最多选择10张图片！");
          img.map((item) => {
            _this.formValidate.sliderImages.push(item.sattDir)
          });
        }
        if (tit === '1' && num === 'dan') {
          _this.OneattrValue[0].image = img[0].sattDir
        }
        if (tit === '1' && num === 'duo') {
          _this.ManyAttrValue[i].image = img[0].sattDir
        }
        if (tit === '1' && num === 'pi') {
          _this.oneFormBatch[0].image = img[0].sattDir
        }
      }, tit, 'content')
    },
    handleSubmitUp() {
      // this.currentTab --
      if (this.currentTab-- < 0) this.currentTab = 0;
    },
    handleSubmitNest(name) {
      this.$refs[name].validate((valid) => {
        if (valid) {
          if (this.currentTab++ > 2) this.currentTab = 0;
        } else {
          if (!this.formValidate.store_name || !this.formValidate.cate_id || !this.formValidate.keyword
              || !this.formValidate.unit_name || !this.formValidate.store_info
              || !this.formValidate.image || !this.formValidate.slider_image) {
            this.$message.warning("请填写完整商品信息！");
          }
        }
      })
    },
    // 提交
    handleSubmit: Debounce(function (name) {
      this.onChangeGroup()
      if (this.formValidate.specType && this.formValidate.attr.length < 1) return this.$message.warning("请填写多规格属性！");
      this.formValidate.cateId = this.formValidate.cateIds.join(',')
      this.formValidate.sliderImage = JSON.stringify(this.formValidate.sliderImages)
      if (this.formValidate.specType) {
        this.formValidate.attrValue = this.ManyAttrValue;
        this.formValidate.attr = this.formValidate.attr.map((item) => {
          return {
            attrName: item.attrName,
            id: item.id,
            attrValues: item.attrValue.join(','),
          }
        })
        for (var i = 0; i < this.formValidate.attrValue.length; i++) {

          this.$set(this.formValidate.attrValue[i], 'id', 0);
          this.$set(this.formValidate.attrValue[i], 'productId', 0);

          this.$set(this.formValidate.attrValue[i], 'attrValue', JSON.stringify(this.formValidate.attrValue[i].attrValue)); //
          delete this.formValidate.attrValue[i].value0

          console.log(this.formValidate.attrValue[i]);
        }
      } else {
        this.formValidate.attr = [{
          attrName: '规格',
          attrValues: '默认',
          id: this.$route.params.id ? this.formValidate.attr[0].id : 0
        }]
        this.OneattrValue.map(item => {
          this.$set(item, 'attrValue', JSON.stringify({'规格': '默认'}))
        })
        this.formValidate.attrValue = this.OneattrValue
      }
      this.$refs[name].validate((valid) => {
        if (valid) {
          this.fullscreenLoading = true
          this.$message('提交中请稍候');
          this.$route.params.id ? productUpdateApi(this.formValidate).then(async res => {
            this.$message.success('编辑成功');
            setTimeout(() => {
              this.$router.push({path: '/store/index'});
            }, 500);
            this.fullscreenLoading = false
          }).catch(res => {
            this.fullscreenLoading = false
          }) : productCreateApi(this.formValidate).then(async res => {
            this.$message.success('新增成功');
            setTimeout(() => {
              this.$router.push({path: '/store/index'});
            }, 500);
            this.fullscreenLoading = false
          }).catch(res => {
            this.fullscreenLoading = false
          })
        } else {
          if (!this.formValidate.storeName || !this.formValidate.cateId || !this.formValidate.keyword
              || !this.formValidate.unitName || !this.formValidate.storeInfo || !this.formValidate.image || !this.formValidate.sliderImages) {
            this.$message.warning("请填写完整商品信息！");
          }
        }
      });
    }),
    // 表单验证
    validate(prop, status, error) {
      if (status === false) {
        this.$message.warning(error);
      }
    },
    // 移动
    handleDragStart(e, item) {
      if (!this.isDisabled) this.dragging = item;
    },
    handleDragEnd(e, item) {
      if (!this.isDisabled) this.dragging = null
    },
    handleDragOver(e) {
      if (!this.isDisabled) e.dataTransfer.dropEffect = 'move'
    },
    handleDragEnter(e, item) {
      if (!this.isDisabled) {
        e.dataTransfer.effectAllowed = 'move'
        if (item === this.dragging) {
          return
        }
        const newItems = [...this.formValidate.sliderImages]
        const src = newItems.indexOf(this.dragging)
        const dst = newItems.indexOf(item)
        newItems.splice(dst, 0, ...newItems.splice(src, 1))
        this.formValidate.sliderImages = newItems;
      }
    },
    handleDragEnterFont(e, item) {
      if (!this.isDisabled) {
        e.dataTransfer.effectAllowed = 'move'
        if (item === this.dragging) {
          return
        }
        const newItems = [...this.formValidate.activity]
        const src = newItems.indexOf(this.dragging)
        const dst = newItems.indexOf(item)
        newItems.splice(dst, 0, ...newItems.splice(src, 1))
        this.formValidate.activity = newItems;
      }
    },
    getGoodsType() {
      /** 让商品推荐列表的name属性与页面设置tab的name匹配**/
      goodDesignList({gid: 70}).then((response) => {
        let list = response.list;
        let arr = [], arr1 = [];
        const listArr = [{name: '是否热卖', value: 'isGood'}];
        let typeLists = [
          {name: '', value: 'isHot', type: '2'},   //热门榜单
          {name: '', value: 'isBenefit', type: '4'}, //促销单品
          {name: '', value: 'isBest', type: '1'}, //精品推荐
          {name: '', value: 'isNew', type: '3'}]; //首发新品
        list.forEach((item) => {
          let obj = {};
          obj.value = JSON.parse(item.value);
          obj.id = item.id;
          obj.gid = item.gid;
          obj.status = item.status;
          arr.push(obj);
        })
        arr.forEach((item1) => {
          let obj1 = {};
          obj1.name = item1.value.fields[1].value;
          obj1.status = item1.status;
          obj1.type = item1.value.fields[3].value;
          arr1.push(obj1);
        })
        typeLists.forEach((item) => {
          arr1.forEach((item1) => {
            if (item.type == item1.type) {
              listArr.push({
                name: item1.name,
                value: item.value,
                type: item.type
              })
            }
          })
        })
        this.recommend = listArr
      })
    },
  }
}
</script>
<style scoped lang="scss">
.disLabel {
  ::v-deep.el-form-item__label {
    margin-left: 36px !important;
  }
}

.disLabelmoren {
  ::v-deep.el-form-item__label {
    margin-left: 120px !important;
  }
}

.priamry_border {
  border: 1px solid #1890FF;
  color: #1890FF;
}

.color-item {
  height: 30px;
  line-height: 30px;
  padding: 0 10px;
  color: #fff;
  margin-right: 10px;
}

.color-list .color-item.blue {
  background-color: #1E9FFF;
}

.color-list .color-item.yellow {
  background-color: rgb(254, 185, 0);
}

.color-list .color-item.green {
  background-color: #009688;
}

.color-list .color-item.red {
  background-color: #ed4014;
}

.proCoupon {
  ::v-deep.el-form-item__content {
    margin-top: 5px;
  }
}

.tabPic {
  width: 40px !important;
  height: 40px !important;

  img {
    width: 100%;
    height: 100%;
  }
}

.noLeft {
  ::v-deep.el-form-item__content {
    margin-left: 0 !important;
  }
}

.tabNumWidth {
  ::v-deep.el-input-number--medium {
    width: 121px !important;
  }

  ::v-deep.el-input-number__increase {
    width: 20px !important;
    font-size: 12px !important;
  }

  ::v-deep.el-input-number__decrease {
    width: 20px !important;
    font-size: 12px !important;
  }

  ::v-deep.el-input-number--medium .el-input__inner {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }

  ::v-deep thead {
    line-height: normal !important;
  }

  ::v-deep .el-table .cell {
    line-height: normal !important;
  }
}

.selWidth {
  width: 100%;
}

.selWidthd {
  width: 300px;
}

.button-new-tag {
  height: 28px;
  line-height: 26px;
  padding-top: 0;
  padding-bottom: 0;
}

.input-new-tag {
  width: 90px;
  margin-left: 10px;
  vertical-align: bottom;
}

.pictrue {
  width: 60px;
  height: 60px;
  border: 1px dotted rgba(0, 0, 0, 0.1);
  margin-right: 10px;
  position: relative;
  cursor: pointer;

  img {
    width: 100%;
    height: 100%;
  }

  video {
    width: 100%;
    height: 100%;
  }
}

.btndel {
  position: absolute;
  z-index: 1;
  width: 20px !important;
  height: 20px !important;
  left: 46px;
  top: -4px;
}

.labeltop {
  ::v-deep.el-form-item__label {
    float: none !important;
    display: inline-block !important;
    width: auto !important;
  }
}

.iview-video-style {
  width: 300px;
  height: 180px;
  border-radius: 10px;
  background-color: #707070;
  margin: 0 120px 20px;
  position: relative;
  overflow: hidden;
}

.iview-video-style .iconv {
  color: #fff;
  line-height: 180px;
  width: 50px;
  height: 50px;
  display: inherit;
  font-size: 26px;
  position: absolute;
  top: -74px;
  left: 50%;
  margin-left: -25px;
}

.iview-video-style .mark {
  position: absolute;
  width: 100%;
  height: 30px;
  top: 0;
  background-color: rgba(0, 0, 0, 0.5);
  text-align: center;
}
</style>
